﻿/*
 *   _____                                ______
 *  /_   /  ____  ____  ____  _________  / __/ /_
 *    / /  / __ \/ __ \/ __ \/ ___/ __ \/ /_/ __/
 *   / /__/ /_/ / / / / /_/ /\_ \/ /_/ / __/ /_
 *  /____/\____/_/ /_/\__  /____/\____/_/  \__/
 *                   /____/
 *
 * Authors:
 *   钟峰(Popeye Zhong) <zongsoft@gmail.com>
 *
 * Copyright (C) 2010-2020 Zongsoft Studio <http://www.zongsoft.com>
 *
 * This file is part of Zongsoft.Core library.
 *
 * The Zongsoft.Core is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as published by
 * the Free Software Foundation, either version 3.0 of the License,
 * or (at your option) any later version.
 *
 * The Zongsoft.Core is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 * GNU Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with the Zongsoft.Core library. If not, see <http://www.gnu.org/licenses/>.
 */

using System;
using System.Runtime.Serialization;

namespace Zongsoft.Services
{
	[Serializable]
	public class CommandOptionException : Zongsoft.Services.CommandException
	{
		#region 构造函数
		public CommandOptionException(string optionName) : this(optionName, null)
		{
		}

		public CommandOptionException(string optionName, string message) : base(message)
		{
			if(string.IsNullOrEmpty(optionName))
				throw new ArgumentNullException(nameof(optionName));

			this.OptionName = optionName.Trim();
		}

		protected CommandOptionException(SerializationInfo info, StreamingContext context) : base(info, context)
		{
			this.OptionName = info.GetString(nameof(OptionName));
		}
		#endregion

		#region 公共属性
		public string OptionName
		{
			get;
		}

		public override string Message
		{
			get
			{
				var message = base.Message;
				return string.IsNullOrEmpty(message) ? string.Format(Properties.Resources.Text_InvalidCommandOption, this.OptionName) : message;
			}
		}
		#endregion

		#region 重写方法
		public override void GetObjectData(SerializationInfo info, StreamingContext context)
		{
			//调用基类同名方法
			base.GetObjectData(info, context);

			//将定义的属性值加入持久化信息集中
			info.AddValue(nameof(OptionName), this.OptionName);
		}
		#endregion
	}
}
